php - utf8_encode 函数用途
全部标签 我在尝试将散列转换为json字符串时遇到错误JSON::GeneratorError:sourcesequenceisillegal/malformedutf-8。我想知道这是否与编码有关,我怎样才能让to_json只按原样对待\xAE?$irb2.0.0-p247:001>require'json'=>true2.0.0-p247:002>a={"description"=>"iPhone\xAE"}=>{"description"=>"iPhone\xAE"}2.0.0-p247:003>a.to_jsonJSON::GeneratorError:sourcesequenceisi
是否有在Ruby1.8.7(或Rails2.x)中使用String.force_encoding()的解决方案,以便它像在Ruby1.9中一样工作?我读了一些关于requireactive_support的内容,但这不起作用$>gem列表--本地|grep'rails\|activesupport'activesupport(3.0.3,2.3.8,2.3.5)rails(2.3.8,2.3.5)$>ruby-vruby1.8.7(2010-08-16patchlevel302)[i686-darwin10.4.0]$>rails-vRails2.3.8IRB:>require"rub
在时间紧迫的脚本中,我们有几个地方可以将旧ID转换为字符串。目前,我们在函数内部使用case语句,如下所示:defget_nameidcaseidwhen1"onething"when3"otherthing"else"defaultthing"endend我正在考虑将其替换为哈希查找,如下所示:NAMES={1=>"onething",3=>"otherthing",}NAMES.default="defaultthing"感觉使用NAMES[id]应该比使用get_name(id)更快-但真的是这样吗? 最佳答案 首先,有几点。
我有课,Foo。我希望能够向构造函数传递一个Foo实例,foo并返回相同的实例。换句话说,我希望这个测试通过:classFoo;endfoo=Foo.newbar=Foo.new(foo)assert_equalfoo,bar有人知道我该怎么做吗?我试过这个:classFoodefinitialize(arg=nil)returnargifargendendfoo=Foo.newbar=Foo.new(foo)assert_equalfoo,bar#=>fails但它不起作用。帮忙吗?编辑因为很多人问过我的理由:我正在对大量数据(许多TB)进行快速分析,并且我将拥有大量对象的大量实例。
在输入编码未知的Ruby1.9中,是否有一种公认的方法来处理正则表达式?假设我的输入恰好是UTF-16编码的:x="foobarbaz"y=x.encode('UTF-16LE')re=/(.*)/x.match(re)=>#bar"1:"bar">y.match(re)Encoding::CompatibilityError:incompatibleencodingregexpmatch(US-ASCIIregexpwithUTF-16LEstring)我目前的方法是在内部使用UTF-8并在必要时重新编码(副本)输入:ify.methods.include?(:encode)#Rub
我试图找出URI.escape和URI.encode之间的区别ruby。两者都没有按照我的意愿进行,即对URL进行完全编码。例如,我希望http://my.web.com为http%3A%2F%2Fmy%2Eweb%2Ecom 最佳答案 没有区别。在Ruby1.9.3中encodeissimplyanaliasforescape.[编辑]请注意,这些方法允许对字符的“不安全”描述符进行编码:URI.encode('http://my.web.com',/\W/)#=>"http%3A%2F%2Fmy%2Eweb%2Ecom"谢谢@m
在我的一千行Ruby之旅中,我对匿名函数的概念感到非常困难。维基百科sayssomethingabout代码中有一些无名的灵魂,它服从于更高的秩序,但我的理解到此为止。或者换句话说,我将如何(当我理解它时)向我妈妈解释匿名函数? 最佳答案 匿名函数具有以下特征:它没有名字(因此是匿名的)内联定义在您不想要普通功能的开销/形式时使用没有明确引用超过一次,除非作为参数传递给另一个函数 关于ruby-究竟什么是匿名函数?,我们在StackOverflow上找到一个类似的问题:
查看Ruby的Base64.encode的源代码,我无法确定字符串转换为哪种字符编码,如果有的话,在Base64中对该数据进行编码之前。以Base64编码的Utf-8字符串与以Base64编码的Utf-16字符串有很大不同。Ruby是否对此操作做出任何promise? 最佳答案 在base64中编码和解码utf-8字符串的示例:text="intérnalionálização"=>"intérnalionálização"text.encoding=>#encoded=Base64.encode64(text)=>"aW50w6l
我有一个Ruby脚本,它在Linux机器上远程生成一个UTF8CSV文件,然后通过SFTP将该文件传输到Windows机器。然后我需要用Excel打开这个文件,但是Excel没有UTF8,所以我总是需要在能够将UTF8转换为ANSI的文本编辑器中打开这个文件。我很乐意使用Ruby以编程方式执行此操作并避免手动转换步骤。最简单的方法是什么?PS:我尝试使用iconv但没有成功。 最佳答案 ascii_str=yourUTF8text.unpack("U*").map{|c|c.chr}.join假设您的文本确实适合ascii字符集。
一些字符,例如Unicode字符'LATINSMALLLETTERCWITHCARON'可以编码为0xC40x8D,但也可以用'LATINSMALLLETTERC'和'COMBININGCARON',即0x630xcc0x8c。更多信息在这里:http://www.fileformat.info/info/unicode/char/10d/index.htm我想知道是否有一个库可以将“LATINSMALLLETTERC”+“COMBININGCARON”转换为“LATINSMALLLETTERCWITHCARON”。或者是否有包含这些转化的表格? 最佳答案